NextJs / View / Call child function from parent
Call child function from parent
-
1. Files
Option 1. using useImperativeHandle
1. Wrap the Child component in a forwardRef.
2. Use the useImperativeHandle hook in the child to add a function to the Child.
3. Call the Child's function from the Parent using the ref, e.g. childRef.current.childFunction().
import {forwardRef, useImperativeHandle, useRef} from 'react'; const Child = forwardRef((props, ref) => { useImperativeHandle(ref, () => ({ childFunction1() { console.log('child function 1 called'); }, childFunction2() { console.log('child function 2 called'); }, })); return ( child content
parent content
The forwardRef method accepts a function that takes the props and a ref as parameters. Option 2. using useEffect
1. Declare a count state variable in the Parent component.
2. Add the count variable to the dependencies of the useEffect hook in the Child.
3.Increment the count in the Parent to rerun the child's useEffect.
import {useEffect, useState} from 'react'; const Child = ({count}) => { useEffect(() => { const childFunction1 = () => { console.log('child function 1 called'); }; const childFunction2 = () => { console.log('child function 2 called'); }; // 👇️ don't run on the initial render if (count !== 0) { childFunction1(); childFunction2(); } }, [count]); return ( child content
parent content
1. We added the count variable to the dependencies of the useEffect hook, so every time it changes, the function we passed to useEffect is going to run. 2.The Parent can run the logic in the Child's useEffect hook by changing the count state variable.